今天我們將使用上篇文章中所建立的模型,來進行訓練,並且查看結果。
model.compile(loss='categorical_crossentropy',
optimizer='adam',
metrics=['accuracy']
)
設定損失函數,最佳化方法,以及評估模型等。
train_history=model.fit(x=x_train4_nor,y=y_train_one,validation_split=0.1,epochs=15,batch_size=300,verbose=2)
x=>影像特徵值
y=>影像實際值
validation_split=>設定訓練及驗證資料比例
epochs=>訓練周期
batch_size=>每一批次多少筆資料
verbose=>顯示訓練過程
def plot_images_labels(images,labels,prediction,idx,num=10):
fig=plt.gcf()
fig.set_size_inches(12,14)
if num>25:
num=15
for i in range(0,num):
ax=plt.subplot(5,5,1+i)
ax.imshow(np.reshape(images[idx],(28,28)), cmap='binary')
title="label=" +str(labels[idx])
if len(prediction)>0:
title+=",predict="+str(prediction[idx])
ax.set_title(title,fontsize=10)
ax.set_xticks([])
ax.set_yticks([])
idx=idx+1
plt.show()
前面有使用過,不多講。
prediction=model.predict_classes(x_test_nor)
plot_images_labels(x_test,y_test,prediction,idx=300)
第1行:輸入影像,並儲存結果。
第3行:印出預測值,從第300筆開始,印10筆,也就是(300-309)。
import pandas as pd
pd.crosstab(y_test,prediction,rownames=['label'],colnames=['predict'])
引入pandas crosstab函式來建立混淆矩陣。
經過了這幾天的文章,我們可以發現keras的程式碼會比純粹的TensofFlow還要簡單,而使用CNN進行預測的準確機率,又會把使用多層感知器來訓練還要來的高。